package com.example.conference.SaToken;

import cn.dev33.satoken.stp.StpInterface;
import com.example.conference.domain.User;
import com.example.conference.domain.vo.UserVo;
import com.example.conference.mapper.UserMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

import java.util.ArrayList;
import java.util.List;

/**
 * 自定义权限验证接口扩展
 */

@Component    // 保证此类被SpringBoot扫描，完成Sa-Token的自定义权限验证扩展
public class StpInterfaceImpl implements StpInterface {
    /**
     * 返回一个账号所拥有的权限码集合
     */
    @Autowired
    UserMapper userMapper;
    @Override
    public List<String> getPermissionList(Object loginId, String loginType) {
        // 本list仅做模拟，实际项目中要根据具体业务逻辑来查询权限
        List<String> list = new ArrayList<String>();
        Integer useId = Integer.parseInt(loginId.toString());
        UserVo u = userMapper.queryByIdToVo(useId);

        String Permission = u.getRole().getRoleName();
        switch (Permission) {
            case "管理员" -> list.add("admin");
            case "教师" -> list.add("teacher");
            case "学生" -> list.add("student");
        }
        return list;
    }

    /**
     * 返回一个账号所拥有的角色标识集合 (权限与角色可分开校验)
     */
    @Override
    public List<String> getRoleList(Object loginId, String loginType) {
        // 本list仅做模拟，实际项目中要根据具体业务逻辑来查询角色
        List<String> list = new ArrayList<String>();
        list.add("admin");
        list.add("super-admin");
        return list;
    }

}